草庐IT

C++ 任意长度整数

全部标签

c# - c#中可变长度字符串的固定长度数字哈希码

我需要存储从可变长度字符串生成的固定长度(最多8位)数字。散列不必是唯一的。它只需要在输入字符串更改时更改。.Net中是否有执行此操作的哈希函数?谢谢基肖尔。 最佳答案 我假设您这样做是因为您需要将值存储在别处并与它进行比较。因此,Zach的回答(虽然完全正确)可能会给您带来问题,因为String.GetHashCode()的契约(Contract)明确说明了其更改范围。因此这是一个固定的并且可以在其他语言中轻松重复的版本。我假设您会在编译时知道可用的小数位数。这是基于Jenkins一次一个哈希(由BretMulvey实现和exha

c# - 用两个标准排序,字符串升序,整数升序

如何根据两个不同的条件进行排序?例如,我有如下人员对象:Person具有属性FirstName(字符串),LastName,和Rank(整数)。示例数据如下:XavierSmith1AlexanderSmith2AlexanderSmith1BobHawke2它应该按名字字母顺序排序,然后按等级排序,例如结果:AlexanderSmith1AlexanderSmith2BobHawke2XavierSmith1到目前为止,我已经尝试了以下方法,但它无法正常工作:peopleList是ListpeopleList.Sort(newComparison((x,y)=>x.Rank.Comp

c# - 根据字节长度缩短UTF8字符串的最佳方法

最近的一个项目要求将数据导入Oracle数据库。将执行此操作的程序是C#.Net3.5应用程序,我正在使用Oracle.DataAccess连接库来处理实际的插入。我遇到一个问题,在插入特定字段时会收到以下错误消息:ORA-12899值对于X列太大我使用了Field.Substring(0,MaxLength);,但仍然出现错误(尽管不是每条记录)。最终,我看到了应该是显而易见的东西,我的字符串是ANSI,字段是UTF8。它的长度以字节为单位,而不是字符。这使我想到了我的问题。修剪弦线以固定MaxLength的最佳方法是什么?我的子字符串代码按字符长度工作。是否有简单的C#函数可以按字

c# - 按值对字典(字符串,整数)进行排序

所以基本上我对交给我的任务有疑问。我不会让您厌烦任务本身的细节,所以我只会为您提供相关信息。我有一本字典,我需要按最高的int[value]排序,准确地说是前五名,我还需要能够显示后五名。Dictionarydict=newDictionary();字符串(键)包含已为文本文件读取的单词。整数(值)保存它们在文档中被提及的次数。我本来打算用另一种方式来做,但有人告诉我要用字典来做,所以请字典帮忙。如果您能解释应该如何完成,我将不胜感激,这样我就可以学习并完成任务,因为该任务的目的是self教育,但我发现它有点困难..非常感谢您提前提供的所有帮助,如果需要更多信息,请告诉我,我会发布!

c# - 为什么编译器允许将 Convert.ToString() 分配给整数?

我不小心在我的代码中偶然发现了类似于下面的东西,它编译得很好,但在运行时显然是炸弹:dynamicfiftySixDynamic=56;intfiftySixInt=System.Convert.ToString(fiftySixDynamic);Convert.ToString()的每次重载都会返回一个字符串,所以这肯定不应该编译?这是怎么回事? 最佳答案 您正在使用dynamic作为Convert.ToString的输入。因为输入是动态,方法绑定(bind)和类型检查被推迟到运行时,所以编译器看不到唯一可能的返回类型是strin

c# - 一组超过 2 个整数的最大公约数

StackOverflow上有几个问题讨论如何找到两个值的最大公约数。一个好的答案显示了一个整洁的recursivefunction来做到这一点。但是如何找到一组超过2个整数的GCD?我似乎找不到这方面的例子。谁能推荐最有效的代码来实现这个功能?staticintGCD(int[]IntegerSet){//whatgoeshere?} 最佳答案 这里有使用链接问题中的LINQ和GCD方法的代码示例。它使用其他答案中描述的理论算法......GCD(a,b,c)=GCD(GCD(a,b),c)staticintGCD(int[]nu

c# - 如何对整数的各个数字求和?

我有一个整数值(例如:723),我想将这个整数中的所有值相加,直到得到一个值。ex:7+2+3=121+2=3我是C#新手。请给我一个很好的答案解释:) 最佳答案 尽管取出底部数字并除以10的解决方案是正确的并且清楚地实现了所需的功能,但如果您知道诀窍,则可以用远更少的代码完成此任务。如果按照您描述的方式对数字求和,直到得到一位数,您得到的结果是原始数字除以9的余数。尝试一下。789-->7+8+9=24-->2+4-->6,并且789=87*9+6因此,如果x是正整数,您只需执行x%9即可解决您的问题。如果你得到零,那么真正的结果

c# - 如何以任意序列搜索模式?

正则表达式仅适用于字符串,但如果该功能不仅可以扩展到字符,还可以扩展到对象,甚至进一步扩展到函数,那会怎样呢?假设我们的对象是整数,它们可以按任何顺序排列:12345678910111213你要解决的任务是像这样找到素数对(或类似的模式搜索任务):{prime}{anyNumber}{prime}所以答案是这样的:(3,4,5)(5,6,7)(11,12,13)或者更复杂的素数链示例:{prime}({anyNumber}{prime})+回答:(3,(4,5),(6,7))(11,(12,13))很像Regex的工作方式,对吧?发生的事情是你定义了一些名为isPrime(x)的函数,

c# - 如何确定任意 URL 是否与定义的路由匹配

如何判断字符串是否与特定的命名路由匹配?我有这样一条路线:routes.MapRoute("FindYourNewRental","find-your-new-rental/{market}/{community}.html",new{controller="FindYourNewRental",action="Community"});stringurl="http://www.website.com/find-your-new-rental/northerncalifornia/sacramento.html"如何以编程方式判断“url”字符串是否与该路由匹配?像这样://matc

c# - HttpRuntime.Cache 对象中缓存键的最大长度?

我们在ASP.NET中使用HttpRuntime.CacheAPI来缓存从数据库检索的数据。对于这个特定的应用程序,我们的数据库查询具有很多参数,因此我们的缓存键看起来像这样:table=table1;param1=somevalue1;param2=somevalue2;param3=somevalue3;param4=somevalue4;param5=somevalue5;param6=somevalue6...etc...对于某些查询,我们有很多参数,以至于缓存键有几百个字符长。我的问题:这些缓存键的长度是否有限制?在内部,它使用字典,因此理论上查找时间应该是恒定的。但是,我想